const db = require("../db/index");

// 获取用户基本信息的处理函数
exports.getUserInfo = (req, res) => {
  const sql = `select id, username, nickname, user_pic from ev_admin where id=?`;
  db.query(sql, req.user.id, (err, results) => {
    // 1. 执行 SQL 语句失败
    if (err) return res.cc(err);

    // 2. 执行 SQL 语句成功，但是查询到的数据条数不等于 1
    if (results.length !== 1) return res.cc("获取用户信息失败！");

    // 3. 将用户信息响应给客户端
    res.send({
      status: 0,
      message: "获取用户基本信息成功！",
      data: results[0],
    });
  });
};

exports.updateUserInfo = (req, res) => {
  const sql = `update ev_admin set ?  where id=?`;
  db.query(sql, [req.body, req.body.id], (err, results) => {
    // 执行 SQL 语句失败
    if (err) return res.cc(err);

    // 执行 SQL 语句成功，但影响行数不为 1
    if (results.affectedRows !== 1) return res.cc("修改用户基本信息失败！");

    // 修改用户信息成功
    return res.cc("修改用户基本信息成功！", 0);
  });
};

exports.updatePassword = (req, res) => {
  const sql = `select * from ev_admin where id=?`;
  db.query(sql, req.user.id, (err, results) => {
    // 执行 SQL 语句失败
    if (err) return res.cc(err);

    // 检查指定 id 的用户是否存在
    if (results.length !== 1) return res.cc("用户不存在！");

    // TODO：判断提交的旧密码是否正确
    const userinfo = req.body;
    if (userinfo.oldPwd != results[0].password) {
      return res.cc("原密码错误！");
    }
    const sqlStr = `update ev_admin set password=? where id=?`;
    const newPwd = req.body.newPwd;
    db.query(sqlStr, [newPwd, req.user.id], (err, results) => {
      if (err) return res.cc(err);
      if (results.affectedRows !== 1) return res.cc("更新密码失败！");
      res.cc("更新密码成功！", 0);
    });
  });
};
